class Solution:
def __init__(self):
self.prime = [1] * 101
for i in range(2,100,1):
j = i* 2
count = 2
while j <= len(self.prime):
self.prime[j] = 0
count+=1
j = i*count
def solve(self, n):
n = str(n)
for i in range(len(n)):
if n[i] in "14689":
print(1)
print(n[i])
return 1
for i in range(len(n)):
for j in range(i+1 , len(n) , 1):
if self.prime[int(n[i] + n[j])]:
continue
else:
print(2)
print(n[i]+ n[j])
return 1
obj = Solution()
t = int(input())
for _ in range(t):
x = int(input())
n = int(input())
obj.solve(n)
#include<bits/stdc++.h>
#include<ext/pb_ds/assoc_container.hpp>
#include<ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_pbds;
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
typedef string str;
typedef pair<int, int> pi;
typedef pair<ll, ll> pl;
typedef pair<ull, ull> pul;
typedef pair<ld, ld> pld;
typedef pair<double,double> pd;
typedef vector<int> vi;
typedef vector<ll> vl;
typedef vector<ull> vul;
typedef vector<bool> vb;
typedef vector<double> vd;
typedef vector<ld> vld;
typedef vector<str> vs;
typedef vector<pi> vpi;
typedef vector<pl> vpl;
typedef vector<pul> vpul;
typedef vector<pld> vpld;
typedef vector<pd> vpd;
typedef vector<vi> vvi;
typedef vector<vl> vvl;
template<class T>
using indexed_set = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update> ;
//indexed_set<int> s;
//cout<<(*s.find_by_order(2)); ->Gives element at 2nd index(0 based indexing)
//cout<<s.order_of_key(5); ->gives number of elements strictly less than 5
//We can also use all the methods provided by a normal set. Ex. s.lower_bound(val)
//Works with dbg too!! (yay :P)
#define mp make_pair
#define pb push_back
#define F first
#define S second
#define lb lower_bound
#define ub upper_bound
#define ins insert
#define rsz resize
#define sz(x) (int)x.size()
#define beg(x) x.begin()
#define en(x) x.end()
#define all(x) beg(x), en(x)
#define rall(x) x.rbegin(), x.rend()
#define sortall(x) sort(all(x))
#define FOR(i,a,b) for (int i = (a); i < (b); ++i)
#define F0R(i,a) FOR(i,0,a)
#define ROF(i,a,b) for (int i = (b)-1; i >= (a); --i)
#define R0F(i,a) ROF(i,0,a)
#define rep(a) F0R(_,a)
#define each(a,x) for (auto& a: x)
#define tr(it, x) for(auto it = beg(x); it != en(x); ++it)
#define clr(x,i) memset(x, i, sizeof(x))
// ************************DEBUG START********************************
#ifdef chemecocs
// #define cerr cout // if you want to print to stdout, uncomment this
template <class T1, class T2>
ostream &operator<<(ostream &os, const pair<T1, T2> &p) {
return os << '{' << p.first << ", " << p.second << '}';
}
template <class T, class = decay_t<decltype(*begin(declval<T>()))>,
class = enable_if_t<!is_same<T, string>::value>>
ostream &operator<<(ostream &os, const T &c) {
os << '[';
tr(it,c)
os << &", "[2 * (it == beg(c))] << *it;
return os << ']';
}
//support up to 5 args
#define _NTH_ARG(_1, _2, _3, _4, _5, _6, N, ...) N
#define _FE_0(_CALL, ...)
#define _FE_1(_CALL, x) _CALL(x)
#define _FE_2(_CALL, x, ...) _CALL(x) _FE_1(_CALL, __VA_ARGS__)
#define _FE_3(_CALL, x, ...) _CALL(x) _FE_2(_CALL, __VA_ARGS__)
#define _FE_4(_CALL, x, ...) _CALL(x) _FE_3(_CALL, __VA_ARGS__)
#define _FE_5(_CALL, x, ...) _CALL(x) _FE_4(_CALL, __VA_ARGS__)
#define FOR_EACH_MACRO(MACRO, ...) \
_NTH_ARG(dummy, ##__VA_ARGS__, _FE_5, _FE_4, _FE_3, _FE_2, _FE_1, _FE_0) \
(MACRO, ##__VA_ARGS__)
//Change output format here
#define out(x) #x " = " << x << "; "
#define dbg(...) \
cerr << __func__ << ":" << __LINE__ << ": " FOR_EACH_MACRO(out, __VA_ARGS__) << "\n"
#define dnl(x) \
cerr <<"----------- Test Case # " << x << " -----------\n"
#else
#define dbg(...)
#define dnl(x)
#endif
// ************************DEBUG END**********************************
// ************************MATH START*********************************
ll gcd(ll a, ll b) {if (b > a) {return gcd(b, a);} if (b == 0) {return a;} return gcd(b, a % b);}
ll expo(ll a, ll b, ll mod) {a %= mod; ll res = 1; while (b > 0) {if (b & 1)res = (res * a) % mod; a = (a * a) % mod; b = b >> 1;} return res;}
void extendgcd(ll a, ll b, ll*v) {if (b == 0) {v[0] = 1; v[1] = 0; v[2] = a; return ;} extendgcd(b, a % b, v); ll x = v[1]; v[1] = v[0] - v[1] * (a / b); v[0] = x; return;} //pass an array of size3. returns solution of equation ax + by = gcd(a,b). v[0] = x, v[1] = y, v[2] = gcd(a,b)
ll mminv(ll a, ll b) {ll arr[3]; extendgcd(a, b, arr); return arr[0];} //for non prime b
ll mminvprime(ll a, ll b) {return expo(a, b - 2, b);}
bool revsort(ll a, ll b) {return a > b;}
void swap(int &x, int &y) {int temp = x; x = y; y = temp;}
ll combination(ll n, ll r, ll m, vector<ll>& fact, vector<ll>& ifact) {ll val1 = fact[n]; ll val2 = ifact[n - r]; ll val3 = ifact[r]; return (((val1 * val2) % m) * val3) % m;}
void google(int t) {cout << "Case #" << t << ": ";}
vector<ll> sieve(int n) {int*arr = new int[n + 1](); vector<ll> vect; for (int i = 2; i <= n; i++)if (arr[i] == 0) {vect.push_back(i); for (int j = 2 * i; j <= n; j += i)arr[j] = 1;} return vect;}
ll mod_add(ll a, ll b, ll m) {a = a % m; b = b % m; return (((a + b) % m) + m) % m;}
ll mod_mul(ll a, ll b, ll m) {a = a % m; b = b % m; return (((a * b) % m) + m) % m;}
ll mod_sub(ll a, ll b, ll m) {a = a % m; b = b % m; return (((a - b) % m) + m) % m;}
ll mod_div(ll a, ll b, ll m) {a = a % m; b = b % m; return (mod_mul(a, mminvprime(b, m), m) + m) % m;} //only for prime m
ll ceil_div(ll a, ll b) {return (a+b-1)/b;}
ll phin(ll n) {ll number = n; if (n % 2 == 0) {number /= 2; while (n % 2 == 0) n /= 2;} for (ll i = 3; i <= sqrt(n); i += 2) {if (n % i == 0) {while (n % i == 0)n /= i; number = (number / i * (i - 1));}} if (n > 1)number = (number / n * (n - 1)) ; return number;} //O(sqrt(N))
// ************************MATH END**********************************
void ipgraph(int n, int m);
void dfs(int u, int par);
const int MOD = 1'000'000'007;
const int MOD2 = 998244353;
const int INF = 2e9;
const ll INFL = 2e18;
const int N = 3e5, M = N;
//=======================
vvi g(N);
vi v(N);
const int Z = 1e2 + 10; //change this for faster computation
vi isPrime(Z,1);
vi primes; //Stores all prime numbers from 1 to n
vi lp(Z,-1); //lp stores lowest prime factor for all numbers from 1 to n
vi hp(Z); //hp stores highest prime factor for all numbers from 1 to n
//Declare the above in global scope
void sieve(){ // O(NlglgN)
isPrime[0] = isPrime[1] = 0;
for(int i = 2; i < Z; ++i){
if(isPrime[i]){
primes.pb(i);
lp[i] = hp[i] = i;
for(int j = 2*i; j < Z; j += i){
isPrime[j] = 0;
if(lp[j] == -1) lp[j] = i;
hp[j] = i;
}
}
}
}
void preSolve(){
sieve();
}
void solve() {
int k; cin>>k;
string s; cin>>s;
// Try all the one digit numbers
for(int i = 0; i < k; ++i){
if(!isPrime[s[i] - '0']){
cout<< 1 << "\n" << s[i] << "\n";
return;
}
}
// Try all two digit numbers
for(int i = 0; i < k - 1; ++i){
string temp;
temp.pb(s[i]);
for(int j = i+1; j < k; ++j){
temp.pb(s[j]);
int num = stoi(temp);
if(!isPrime[num]){
cout<< 2 << "\n" << temp << "\n";
return;
}
temp.pop_back();
}
}
}
inline namespace FileIO {
void setIn(str s) { freopen(s.c_str(),"r",stdin); }
void setOut(str s) { freopen(s.c_str(),"w",stdout); }
void setErr() { freopen("Error.out","w",stderr); }
void setIO(str s = "") {
cin.tie(0)->sync_with_stdio(0); // unsync C / C++ I/O streams
// cin.exceptions(cin.failbit);
// throws exception when do smth illegal
// ex. try to read letter into int
if (sz(s)) setIn(s+".in"), setOut(s+".out"); // for old USACO
#ifdef chemecocs
setErr();
#endif
}
}
int main() {
setIO();
int t = 1;
cin >> t;
cout<<fixed<<setprecision(10);
preSolve();
F0R(i,t) {
dnl(i+1);
solve();
}
return 0;
}
void ipgraph(int n, int m){
int i, u, v;
while(m--){
cin>>u>>v;
u--, v--;
g[u].pb(v);
g[v].pb(u);
}
}
void dfs(int u, int par){
for(int v:g[u]){
if (v == par) continue;
dfs(v, u);
}
}
361A - Levko and Table | 5E - Bindian Signalizing |
687A - NP-Hard Problem | 1542C - Strange Function |
961E - Tufurama | 129D - String |
888A - Local Extrema | 722B - Verse Pattern |
278A - Circle Line | 940A - Points on the line |
1742C - Stripes | 1742F - Smaller |
1742B - Increasing | 1742A - Sum |
1742D - Coprime | 390A - Inna and Alarm Clock |
1398B - Substring Removal Game | 1742G - Orray |
416B - Art Union | 962A - Equator |
803B - Distances to Zero | 291A - Spyke Talks |
1742E - Scuza | 1506D - Epic Transformation |
1354G - Find a Gift | 1426F - Number of Subsequences |
1146B - Hate "A" | 1718C - Tonya and Burenka-179 |
834A - The Useless Toy | 1407D - Discrete Centrifugal Jumps |